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DETAILED ACTION 



This action is in response to the amendment filed on 4/1/04. 



2. The rejection under 35 U.S.C. 1 12, first paragraph, to claims 1-26, 28-33, 36 and 41-47 is 
withdrawn in view of appUcant's amendments. 

3. The rejection under 35 U.S.C. 102(b) as being anticipated by Fortin (U.S. 5,528,753) to 
claims 1-2, 4-16, 18-20, 28-33, 36 and 41-47 is moot in view of the new ground(s) of rejection. 

4. The rejection under 35 U.S.C. 103(a) as being unpatentable over Fortin (U.S. 5,528,753) 
to claims 3 and 17 is moot in view of the new ground(s) of rejection. 

5. The rejection under 35 U.S.C. 103(a) as being unpatentable over Fortin (U.S. 5,528,753), 
and further in view of Peek (U.S. 5,481,706) to claims 21-26 is moot in view of the new 
ground(s) of rejection. 

6. Claims 1, 15, 21, 23, 28-31, 36 and 41 have been amended. 

7. Claims 1-26, 28-33, 36 and 41-47 are pending. 

8. Claims 1-20, 28-33, 36 and 41-47 stand finally rejected under 35 U.S.C. 103(a) as being 
unpatentable over Fortin (U.S. 5,528,753) in view of Kaufer (U.S. 5,812,828). 

9. Claims 21-26 stand finally rejected under 35 U.S.C. 103(a) as being unpatentable over 
Fortin (U.S. 5,528,753) in view of Kaufer (U.S. 5,812,828), and further in view of Peek (U.S. 
5,481,706), 



Admitted Prior Art 

10. If Applicant does not seasonably traverse the well-known statement during examination, 
then the object of the well known statement is taken to be admitted prior art. In re Chevenard, 
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139 F,2d 71, 60 USPQ 239 (CCPA 1943). A seasonable challenge constitutes a demand for 
evidence made as soon as practicable during prosecution. Thus, Applicant is charged with 
rebutting the well-known statement in the next reply after the Office action in which the well- 
known statement was made. This is necessary because the Examiner must be given the 
opportunity to provide evidence in the next Office action or explain why no evidence is required. 
If the Examiner adds a reference to the rejection in the next action after applicant's rebuttal, the 
newly cited reference, if it is added merely as evidence of the prior well known statement, does 
not result in a new issue and thus the action can potentially be made final. 

The object of the following well known statements is taken to be admitted prior art: 

See the previous Office Action, Paper No. 14, par. 14 and 15. 



1 1 . The following is a quotation of 35 U.S. C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set forth in 
section 102 of this title, if the differences between the subject matter sought to be patented and the prior art are 
such that the subject matter as a whole would have been obvious at the time the invention was made to a person 
having ordinary skill in the art to which said subject matter pertains. Patentability shall not be negatived by the 
manner in which the invention was made. 



12. Claims 1-20, 28-33, 36 and 41-47 are rejected under 35 U.S.C. 103(a) as being 
unpatentable over Fortin (U.S. 5,528,753) in view of Kaufer (U.S. 5,812,828). 



Response to Amendment 



Claim Rejections - 35 USC § 103 



Per Claim 1 (Amended): 
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Fortin teaches a computerized method for creating an instrumented executable file 
("provide a system and method for efficiently instrumenting stripped object routines executing 
on a computer system" in column 3, lines 19-21); modifying an executable file to invoke a user- 
supplied function in place of an original function, the user-supplied function enabling code to 
control execution of the original function ("The Call to Target still points to address 202. After 
202, however, control is passed to Entry Routine 210. Entry Routine 210 collects the 
information desired by the monitor and returns control to the target routine." in column 4, lines 
46-51); and retaining access information of the original function, the access information enabling 
the user-supplied function to invoke the original function ("The Call to Target still points to 
address 202 . . . returns control to the target routine." in column 4, lines 47-51). Fortin does not 
explicitly teach that the code is fault simulation code, Kaufer teaches fault simulation code 
(column 1, lines 59-64). 

It would have been obvious to one having ordinary skill in the computer art at the time of 
the invention was made to modify the method disclosed by Fortin to include fault simulation 
code using the teaching of Kaufer. The modification would be obvious because one of ordinary 
skill in the art would be motivated to simulate one or more errors during testing of an application 
(Kaufer, column 1, lines 41-44). 

Per Claim 2: 

The rejection of claim 1 is incorporated, and Fortin further teaches the user-supplied 
function is modified to invoke the original function using the retained access information of the 
original function (column 4, lines 49-53). 
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Per Claim 3: 

The rejection of claim 1 is incorporated, and the combination of Fortin and Kaufer further 
teaches that the user-supplied function is in a library (Fortin, column 5, Hnes 20-24). The 
combination of Fortin and Kaufer does not expHcitly teach that the user-suppHed function is in a 
dynamic Hnk Hbrary. Official Notice is taken that it was a common practice to have functions in 
a dynamic link library. 

It would have been obvious to one having ordinary skill in the computer art at the time of 
the invention was made to modify the method disclosed by the combination of Fortin and Kaufer 
to include that the user-supplied function is in a dynamic link library using the teaching of 
common practice. The modification would be obvious because one of ordinary skill in the art 
would be motivated to modify functions without recompiling the program. 

Per Claim 4: 

The rejection of claim 1 is incorporated, and Fortin further teaches the user-suppUed 
function is not exported during compilation (column 5, lines 20-24). 

Per Claim 5: 

The rejection of claim 1 is incorporated, and Fortin further teaches the original function 
and the user-supphed function have identical prototypes (column 4, lines 62-65). 

Per Claim 6: 
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The rejection of claim 1 is incorporated, and Fortin further teaches the user-suppHed 
function is stored in a module that is separate from the executable file (column 5, lines 20-24). 

Per Claim 7: 

The rejection of claim 1 is incorporated, and Fortin further teaches modifying the 
executable file is performed using user-specified set points (column 4, lines 54-65). 

Per Claim 8: 

The rejection of claim 7 is incorporated, and Fortin further teaches determining whether 
the original function implements the thiscall calling convention, and when the determination is 
positive, adding instructions to the executable file to perform pushing the register that holds the 
"this" pointer onto the stack from the invoked original function site when the determining 
indicates that the function implements a thiscall calling convention (column 5, lines 48-51 and 
lines 55-57, and column 6, Hnes 48-58); and swapping the retum value of the invoking original 
function on the stack and the register that holds the "this" pointer value on the stack when the 
determining indicates that the function implements a thiscall calling convention (column 6, lines 
59-67). 

Per Claim 9: 

The rejection of claim 7 is incorporated, and Fortin further teaches modifying the 
executable file further comprises enabling the user-supplied function to invoke the original 
function in the executable file (column 4, lines 49-53). 
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Per Claim 10: 

The rejection of claim 9 is incorporated, and Fortin further teaches adding a jump in the 
user-suppUed function to a function that retrieves the address of the original function (column 6, 
lines 6-18); and adding a jump in the user-supplied function that invokes the original function 
using the address of the original function (column 6, lines 1-5 and lines 35-39). 

Per Claim 11: 

The rejection of claim 1 is incorporated, and Fortin further teaches enabling the user- 
supplied function to alter behavior (column 4, hnes 47-53). 

Per Claim 12: 

The rejection of claim 1 1 is incorporated, and Fortin further teaches enabling the user- 
suppUed function to alter behavior is performed in response to data (column 4, lines 47-53). 

Per Claim 13: 

The rejection of claim 12 is incorporated, and Fortin further teaches the data is retrieved 
from an initialization file ("libinstr.a" in Fig. 7 and column 5, lines 20-24). 

Per Claim 14: 

The rejection of claim 1 is incorporated, and Fortin further teaches saving the address of 
an original function in a threaded local storage variable (column 6, lines 1-5); and creating an 
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entry in a function lookup table associating the address of the original function with the name of 
the original function, wherein the function lookup table is in the instrumented executable file 
(column 5, lines 46-51 and lines 64-67). 

Per Claim 15 (Amended): 

Fortin teaches a computerized method for executing an instrumented executable file 
("provide a system and method for efficiently instrumenting stripped object routines executing 
on a computer system" in column 3, lines 19-21); modifying the instrumented executable file to 
invoke a user-supplied function in place of an original function, the user-supphed function 
enabling code to control execution of the original function, the user-supplied function having a 
jump to the original function ("The Call to Target still points to address 202. After 202, 
however, control is passed to Entry Routine 210. Entry Routine 210 collects the information 
desired by the monitor and returns control to the target routine. . . . The stored target routine first 
instruction is executed in the 'Return to Target' section and control branches to the second 
instruction of the target routine 714." in column 4, lines 46-51 and column 6, lines 56-58); 
saving the address of the original function in a threaded local storage variable ("The 'Retum to 
Target Routine' section 604 contains the 'saved' first instruction of the target routine and direct 
branch to the address of the second instruction of the target routine." in column 6, lines 1-5); and 
invoking the user-supplied function using the address ("Processing begins with a call to the 
target routine 702. This call will encounter the branch first instruction and immediately branch 
to the Entry section 704 . . . that in turn calls 708 user supplied Entry routine" in column 6, lines 
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46-51). Fortin does not explicitly teach that the code is fault simulation code. Kaufer teaches 
fauh simulation code (column 1, lines 59-64). 

It would have been obvious to one having ordinary skill in the computer art at the time of 
the invention was made to modify the method disclosed by Fortin to include fault simulation 
code using the teaching of Kaufer. The modification would be obvious because one of ordinary 
skill in the art would be motivated to simulate one or more errors during testing of an appUcation 
(Kaufer, column 1, lines 41-44). 

Per Claim 16: 

The rejection of claim 1 5 is incorporated, and Fortin further teaches creating a master 
lookup table at initialization wherein the master lookup table associates the base address of the 
instrumented executable file to the address of a function lookup table in the instrumented 
executable file (column 5, lines 47-51 and lines 55-67). 

Per Claim 17; 

The rejection of claim 15 is incorporated, and the combination of Fortin and Kaufer 
further teaches that the saving and the invoking are performed by the original function, and the 
original function being located in the instrumented executable file (Fortin, column 6, lines 44- 
51). The combination of Fortin and Kaufer does not explicitly teach that the original function is 
in a dynamic link library and a stub function of the original function being located in the 
instrumented executable file. Official Notice is taken that it was a common practice to include a 
function in a dynamic link library at the time the instant invention was made. 



\ 
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It would have been obvious to one having ordinary skill in the computer art at the time of 
the invention was made to modify the method disclosed by the combination of Fortin and Kaufer 
to include a function in a dynamic link library using the teaching of common practice. The 
modification would be obvious because one of ordinary skill in the art would be motivated to 
eliminate recompilation of a file, save memory space, and one would also want to provide the 
ease of modifying functions. 

Per Claim 18: 

The rejection of claim 15 is incorporated, and Fortin further teaches wherein original 
function is embedded in the instrumented executable file, and wherein the saving and the 
invoking is performed by the original function (column 6, lines 46-51). 

Per Claim 19: 

The rejection of claim 1 5 is incorporated, and Fortin further teaches invoking the original 
function from within the user-supplied function using the threaded local storage variable (column 
6, lines 56-58). 

Per Claim 20: 

The rejection of claim 19 is incorporated, and Fortin further teaches pushing the register 
that holds the "this" pointer onto the stack from the invoked original function site when the 
determining indicates that the function implements a thiscall calling convention (column 5, lines 
48-51 and hnes 55-57, and column 6, lines 48-58); and swapping the return value of the invoking 
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original function on the stack and the register that holds the "this" pointer value on the stack 
when the determining indicates that the function implements a thiscall calling convention 
(column 6, lines 59-67). 

Per Claim 28 (Amended): 

This is a system version of the claimed method discussed above, claim 1, wherein all 
claim limitations also have been addressed and/or covered in cited areas as set forth above. 
Thus, accordingly, this claim is also obvious. 

Per Claim 29 (Amended): 

This is a system version of the claimed method discussed above (claims 1 and 2), wherein 
all claim limitations also have been addressed and/or covered in cited areas as set forth above, 
including "the original function having an identity comprising a name and a parameter 
prototype" (Fortin, column 4, lines 62-65 and column 5, lines 64-67). Thus, accordingly, this 
claim is also obvious. 

Per Claim 30 (Amended): 

Fortin teaches a computerized system ("provide a system and method for efficiently 
instrumenting stripped object routines executing on a computer system" in column 3, lines 19- 
21); an executable file having a jump to an original function, the original function having an 
identity comprising a name and a parameter prototype ("The stored target routine first instruction 
is executed in the "Return to Target" section and control branches to the second instruction of the 
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target routine 714." in column 5, lines 64-67 to column 6, lines 1-5 and lines 56-58); a first 
software component having a user-supplied fiinction that includes a jump to the original function 
("The Entry routine saves . . . and calls 706 the common Entry code that in turn calls 708 user 
supplied Entry routine . . . The stored target routine first instruction is executed in the "Return to 
Target" section and control branches to the second instruction of the target routine 714." in 
column 5, lines 64-67 to column 6, lines 1-5 and lines 48-58); and a second software component 
for receiving the identity of the original fiinction, receiving the identity of the user-supplied 
function, instrumenting the executable file by modifying the executable file to invoke the identity 
of the user-supplied fixnction in place of the identity of the original fixnction, the identity of the 
user-supplied fiinction enabling code to control execution of the original function ("The routines 
also allow the fiinction of a target routine to be fiiUy replaced such that newly provided code will 
be executed instead of the base code in the routine being monitored." in column 4, lines 62-65); 
and storing the original fiinction address in the executable file in association with the name of the 
original instrumented fiinction ("insertion of the demultiplexor entries 510. A demultiplexor 
entry (demux-entry) is provided for each target routine . . . The data section 602 contains the 
addresses at which the target routine and the target routine's symbolic name reside" in column 5, 
lines 46-51 and lines 64-67). Fortin does not explicitly teach that the code is fault simulation 
code. Kaufer teaches fault simulation code (column 1, hnes 59-64). 

It would have been obvious to one having ordinary skill in the computer art at the time of 
the invention was made to modify the system disclosed by Fortin to include fault simulation code 
using the teaching of Kaufer. The modification would be obvious because one of ordinary skill 
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in the art would be motivated to simulate one or more errors during testing of an application 
(Kaufer, column 1, lines 41-44). 

Per Claim 31 (Amended); 

Fortin teaches a computerized system ("provide a system and method for efficiently 
instrumenting stripped object routines executing on a computer system" in column 3, lines 19- 
21); a first module of machine-readable code comprising a call to an original function, the call 
being directed to a user-supplied function ("The Call to Target still points to address 202. After 
202, however, control is passed to Entry Routine 210. Entry Routine 210 collects the 
information desired by the monitor and returns control to the target routine." in column 4, lines 
47-51); and a first data structure associating the identity of the original function with the location 
of the original function ("A demultiplexor entry (demux-entry) is provided for each target 
routine . . . The data section 602 contains the addresses at which the target routine and the target 
routine's symboUc name reside" in column 5, lines 46-51 and lines 64-67); and a second module 
comprising the user-supplied function, linked to the first module and a jump to the original 
function, the user-supplied function enabling code to control execution of the original function 
("The stored target routine first instruction is executed in the 'Return to Target' section and 
control branches to the second instruction of the target routine 714." in column 6, lines 56-58). 
Fortin does not explicitly teach that the code is fault simulation code. Kaufer teaches fault 
simulation code (column 1, hnes 59-64). 

It would have been obvious to one having ordinary skill in the computer art at the time of 
the invention was made to modify the system disclosed by Fortin to include fault simulation code 
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using the teaching of Kaufer. The modification would be obvious because one of ordinary skill 
in the art would be motivated to simulate one or more errors during testing of an application 
(Kaufer, column 1, lines 41-44). 

Per Claim 32: 

The rejection of claim 31 is incorporated, and Fortin further teaches the first data 
structure comprises a function lookup table readily available for verifying that the threaded local 
storage variable contains the correct original instrumented function address (column 5, lines 64- 
67 to column 6, lines 1-5); and wherein the second module comprises a dynamic linked library 
(column 5, lines 20-24). 

Per Claim 33: 

The rejection of claim 3 1 is incorporated, and Fortin further teaches a second data 
structure associating the location of the first data structure with the location of the first module 
(column 5, lines 47-51 and lines 55-67). 

Per Claim 36 (Amended): 

This is a computer-readable medium version of the claimed method discussed above, 
claim 1, wherein all claim limitations also have been addressed and/or covered in cited areas as 
set forth above. Thus, accordingly, this claim is also obvious. 



Per Claims 41 (Amended) & 43: 
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These are another versions of the claimed method discussed above, claim 1, wherein all 
claim limitations also have been addressed and/or covered in cited areas as set forth above, 
including "replacing the access to the original function with an access to a user-supplied 
function" (Fortin, column 4, lines 46-51). Thus, accordingly, these claims are also obvious. 

Per Claim 42: 

This is another version of the claimed method discussed above, claim 2, wherein all claim 
limitations also have been addressed and/or covered in cited areas as set forth above. Thus, 
accordingly, this claim is also obvious. 

Per Claim 44: 

The rejection of claim 41 is incorporated, and Fortin further teaches wherein replacing 
the access to the original function with the access to the user-supplied function is performed by 
modifying set points stored in a computer-readable medium separate from the executable file 
(column 4, lines 54-65). 

Per Claim 45: 

The rejection of claim 41 is incorporated, and Fortin further teaches wherein retaining 
access information associated with the-original function includes saving the address of the 
original function (column 6, lines 1-5). 



Per Claim 46: 
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The rejection of claim 41 is incorporated, and Fortin further teaches wherein retaining 
access information associated with the original function includes associating the name of the 
original function with the address of original function using a function lookup table (column 5, 
lines 46-51 and lines 64-67). 

Per Claim 47: 

The rejection of claim 46 is incorporated, and Fortin further teaches further comprising 
invoking the original function using the function lookup table (column 5, lines 46-51 and lines 
64-67). 

13. Claims 21-26 are rejected under 35 U.S.C. 103(a) as being unpatentable over Fortin (U.S. 
5,528,753) in view of Kaufer (U.S. 5,812,828), and further in view of Peek (U.S. 5,481,706). 

Per Claims 21 (Amended) & 22: 

Fortin teaches a computerized method for instrumenting an original function in an 
executable file for testing by callers of the original function ("provide a system and method for 
efficiently instrumenting stripped object routines executing on a computer system" in column 3, 
lines 19-21), the original function comprises an instruction that saves the addresss of the original 
function to a threaded local storage variable ("The 'Return to Target Routine' section 604 
contains the 'saved' first instruction of the target routine and direct branch to the address of the 
second instruction of the target routine." in column 6, lines 1-5), replaces an access to the 
original function with an access to a user-supphed function, the user-supplied function enabling 
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code to control execution of the original function ("Processing begins with a call to the target 
routine 702. This call will encounter the branch first instruction and immediately branch to the 
Entry section 704 . . . that in turn calls 708 user supplied Entry routine" in column 6, lines 46-51), 
adding an entry in a function lookup table of the original function ("insertion of the 
demultiplexor entries 510. A demultiplexor entry (demux-entry) is provided for each target 
routine." in column 5, lines 46-51 and lines 64-67), determining if the prototype of the original 
function is correctly specified and indicating an error when the determining indicates an 
incorrectly specified prototype of the original function ("The routines also allow the function of a 
target routine to be fully replaced such that newly provided code will be executed instead of the 
base code in the routine being monitored." in column 4, lines 62-65, inherently determining 
prototype). Fortin does not expUcitly teach an imported function, a stub function for the 
imported function, adding a wrapper of the imported fiinction to an import data block or that the 
code is fault simulation code. 

Official Notice is taken that it was a common practice to include a stub function for an 
imported function at the time the instant invention was made. Kaufer teaches fault simulation 
code (column 1 , lines 59-64). Peek teaches adding a wrapper of a function to a data block 
("providing a "wrapper" for the particular function ... a wrapper will be seen to be an individual 
piece of code placed around a corresponding individual function call or routine" in column 6, 
lines 34-37 and 43-50). 

It would have been obvious to one having ordinary skill in the computer art at the time of 
the invention was made to modify the method disclosed by Fortin to include a stub function for 
an imported function, adding a wrapper of the imported function to an import data block, and 
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fault simulation code using the combined teaching of common practice, Kaufer and Peek. The 
modification would be obvious because one of ordinary skill in the art would be motivated to 
eliminate recompilation of a file and to encapsulate data. 

Per Claims 23 (Amended) & 24-25: 

Fortin teaches a computerized method for instrumenting an original function in an 
executable file for testing by callers of the original function ("provide a system and method for 
efficiently instrumenting stripped object routines executing on a computer system" in column 3, 
lines 19-21), modifying the original function to invoke a user-supplied function in place of the 
original function, the user-supplied function enabling code to control execution of the original 
function ("The Call to Target still points to address 202. After 202, however, control is passed to 
Entry Routine 210. Entry Routine 210 collects the information desired by the monitor and 
returns control to the target routine." in column 4, lines 46-51), adding an entry in a function 
lookup table of the address of the original function ("insertion of the demultiplexor entries 510. 
A demultiplexor entry (demux-entry) is provided for each target routine." in column 5, lines 46- 
51 and lines 64-67), redirecting is accomplished by an instruction that causes a jump to the user- 
supplied function ("Processing begins with a call to the target routine 702, This call will 
encounter the branch first instruction and immediately branch to the Entry section 704 . . . that in 
turn calls 708 user supplied Entry routine" in column 6, lines 46-51), determining whether the 
prototype of the original function is correctly specified, and indicating an error when the 
determining whether the prototype of the original function is correctly specified indicates an 
incorrecdy specified prototype of the original function ("The routines also allow the function of a 
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target routine to be fully replaced such that newly provided code will be executed instead of the 
base code in the routine being monitored " in column 4, lines 62-655 inherently determining 
prototype). Fortin does not explicitly teach an embedded function, modifying an embedded 
function using a wrapper or that the code is fault simulation code. 

Official Notice is taken that it was a common practice to include an embedded function at 
the time the instant invention was made. Kaufer teaches fault simulation code (column 1, lines 
59-64). Peek teaches modifying a function using a wrapper ("providing a "wrapper" for the 
particular function ... a wrapper will be seen to be an individual piece of code placed around a 
corresponding individual function call or routine" in column 6, Unes 34-37 and 43-50). 

It would have been obvious to one having ordinary skill in the computer art at the time of 
the invention was made to modify the method disclosed by Fortin to include an embedded 
function, modifying an embedded function using a wrapper and fault simulation code using the 
combined teaching of common practice, Kaufer and Peek. The modification would be obvious 
because one of ordinary skill in the art would be motivated to encapsulate functions. 

Per Claim 26: 

The rejection of claim 23 is incorporated, and Fortin further teaches that the function 
lookup table is in the executable file (column 5, lines 46-51). 

Response to Arguments 
14. Applicant's arguments with respect to claims 1-26, 28-33, 36 and 41-47 have been 
considered but are moot in view of the new ground(s) of rejection. 





Application/Control Number: 09/503,215 
Art Unit: 2124 



Page 20 



Conclusion 



1 5. Applicant's amendment necessitated the new ground(s) of rejection presented in this 
Office action. Accordingly, THIS ACTION IS MADE FINAL. See MPEP § 706.07(a). 
Applicant is reminded of the extension of time poUcy as set forth in 37 CFR 1. 136(a). 

A shortened statutory period for reply to this final action is set to expire THREE 
MONTHS from the mailing date of this action. In the event a first reply is filed within TWO 
MONTHS of the mailing date of this final action and the advisory action is not mailed until after 
the end of the THREE-MONTH shortened statutory period, then the shortened statutory period 
will expire on the date the advisory action is mailed, and any extension fee pursuant to 37 
CFR 1 . 136(a) will be calculated from the mailing date of the advisory action. In no event, 
however, will the statutory period for reply expire later than SIX MONTHS from the date of this 
final action. 

16. Any inquiry concerning this communication from the examiner should be directed to 
Qamrun Nahar whose telephone number is (703) 305-7699. The examiner can normally be 
reached on Mondays through Thursdays from 9:00 AM to 6:30 PM. The examiner can also be 
reached on altemate Fridays. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Kakali Chaki, can be reached on (703) 305-9662. The fax phone number for the 
organization where this application or processing is assigned is (703) 872-9306. 
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Any inquiry of a general nature or relating to the status of this application or proceeding 
should be directed to the receptionist whose telephone number is (703) 305-3900. 

Information regarding the status of an application may be obtained from the Patent 
Application Information Retrieval (PAIR) system. Status information for published applications 
may be obtained from either Private PAIR or Public PAIR. Status information for unpublished 
applications is available through Private PAIR only. For more information about the PAIR 
system, see http://pair-direct.uspto.gov. Should you have questions on access to the Private PAIR 
system, contact the Electronic Business Center (EBC) at 866-217-9197 (toll-free). 




QN 

June 1, 2004 



KAKAUCH^ 
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